Amendments to and Listing of the Claims: 

Amend claims 9, 15 and 26, and add new claims 34-41 as follows: 

1. (Unamended) A method of executing code of at least one software program in a multi- 
processor computer environment, each software program including (i) a first portion of software 
code to be executed in a computer, and (ii) a second portion of software code that includes one or 
more fragments of code of the software program, the method comprising executing the second 
portion of code in one or more external devices which are in communication with the computer. 

2. (Unamended) The method of claim 1 wherein the second portion of code is encrypted, the 
method further comprising transferring the second portion of code to a secure computer 
environment, and decrypting the second portion of code in the one or more external devices prior 
to execution. 

3. (Unamended) The method of claim 2 wherein the one or more external devices are one or 
more smart cards, each smart card including a processor for executing the second portion of 
code, the smart card being the secure computer environment. 

4. (Unamended) The method of claim 1 wherein the fragments of code are interspersed within 
the first portion of code. 

5. (Unamended) The method of claim 1 wherein the second portion of code is stored in the 
computer, the method further comprising downloading the second portion of code into the one or 
more external devices prior to execution. 

6. (Unamended) The method of claim 1 wherein there are a plurality of software programs, and 
the second portions include fragments from more than one of the software programs. 

7. (Unamended) The method of claim 1 wherein the one or more external devices are tamper- 
resistant. 



8. (Unamended) The method of claim 1 wherein the one or more external devices are one or 
more smart cards. 

9. (Currently Amended) An apparatus which executes code of at least one software program in a 
multi-processor computer environment, each software program including (i) a first portion of 
software code, and (ii) a second portion of software code that includes one or more fragments of 
code of the software program, the apparatus comprising: 

(a) a first computer which executes the first portion; and 

(b) one or more e xternals unit external units in communication with the computer, the one or 
more external units executing the second portion. 

10. (Unamended) The apparatus of claim 9 wherein the second portion of code is encrypted, the 
apparatus further comprising: 

(c) means for transferring the second portion of code to a secure computer environment; and 

(d) means for decrypting the second portion of code in the one or more external devices prior to 
execution. 

11. (Unamended) The apparatus of claim 10 wherein the one or more external devices are one or 
more smart cards, each smart card including a processor for executing the second portion of 
code, the smart card being the secure computer environment. 

12. (Unamended) The apparatus of claim 9 wherein the second portion of code is stored in the 
computer, the apparatus further comprising: 

(e) means for downloading the second portion of code into the one or more external devices prior 
to execution. 

13. (Unamended) The apparatus of claim 9 wherein the one or more external devices are tamper- 
resistant. 

14. (Unamended) The apparatus of claim 9 wherein the one or more external devices are one or 
more smart cards. 



15. (Currently Amended) A method of transforming a computer program which includes 
software code, the method comprising: 

(a) identifying one or more fragments of the software code, 

(b) associating a program call with each of the identified fragments; and 

(c) inserting the program call into the software code, thereby transforming the software computer 
program, wherein when a program call is reached, the respective fragment of software code is 
executed. 

16. (Unamended) The method of claim 15 further comprising: 

(d) encrypting the software code associated with the identified fragments; and 

(e) replacing the fragments with encrypted versions of the software code. 

17. (Unamended) A method of executing a computer program which includes software code, the 
software code having (i) a first portion, and (ii) a second portion, the second portion including 
one or more fragments of the software code and a program call associated with each fragment, 
the method comprising: 

(a) executing the first portion; and 

(b) executing the associated fragments when a program call in the second portion is reached. 

18. (Unamended) The method of claim 17 wherein the first portion executes in a computer, and 
the second portion executes in an external device with respect to the computer, and step (b) 
further comprises sending a fragment to the external device when a program call of the 
associated fragment is reached, and executing the fragment in the external device. 

19. (Unamended) The method of claim 18 wherein step (b) further comprises generating a result 
upon execution of the fragment in the external device, the result being used during subsequent 
execution of the computer program. 

20. (Unamended) The method of claim 18 wherein the external device is a smart card. 



21. (Unamended) The method of claim 17 wherein the one or more fragments are encrypted 
code, the method further comprising: 

(c) decrypting the one or more fragments prior to execution thereof. 

22. (Unamended) An apparatus for executing a computer program which includes software code, 
the software code having (i) a first portion, and (ii) a second portion, the second portion 
including one or more fragments of the software code and a program call associated with each 
fragment, the apparatus comprising: 

(a) means for executing the first portion; and 

(b) means for executing the associated fragments when a program call in the second portion is 
reached. 

23. (Unamended) The apparatus of claim 22 wherein the means for executing the first portion is 
in a computer, and the means for executing the associated fragments is in an external device with 
respect to the computer, and a fragment is sent to the external device when a program call of the 
associated fragment is reached, and is then executed in the external device. 

24. (Unamended) The apparatus of claim 23 wherein the external device is a smart card. 

25. (Unamended) The apparatus of claim 22 wherein the one or more fragments are encrypted 
code, the apparatus further comprising: 

(c) means for decrypting the one or more fragments prior to execution thereof. 

26. (Currently Amended) A method of access control of software code which is executed on a 
smart card that is in communication with a host computer, the smart card having stored therein 
access control parameters for identified software code, the method comprising: 

(a) the host computer uploading software code and its identity data to the smart card; and 

(b) the smart card using the access control parameters and the identity data to determine whether 
access is permissible for the uploaded software code, wherein the software code may be executed 
only if access is permissible. 



27. (Unamended) The method of claim 26 wherein the software code includes one or more 
fragments of software code of a software program that executes at the host computer. 

28. (Unamended) The method of claim 26 wherein access control parameters include one or 
more of permission status, number of runs data, time data, and program variant data. 

29. (Unamended) The method of claim 26 further comprising: 

(c) modifying at least one of the access control parameters subsequent to an initial storage of the 
access control parameters. 

30. (Unamended) A method of executing a plurality of software code fragments of a software 
program on an external unit, wherein the external unit is connected to a computer, the external 
unit including a processor and a memory, the method comprising: 

(a) at execution time of each of the software code fragments, automatically uploading the 
respective software code fragment to the memory of the external unit; and 

(b) executing the respective software code fragment in the external unit using only the processor 
and the memory of the external unit. 

31. (Unamended) The method of claim 30 wherein the software code fragments are encrypted, 
the method further comprising: 

(c) after step (a) and prior to step (b), decrypting the software code fragments. 

32. (Unamended) A method of preparing code of a software program, the software program 
including (i) a first portion of source code to be executed by a first processor, and (ii) a second 
portion of source code to be executed by a second processor, the second portion of source code 
including one or more fragments of code of the software program, the method comprising prior 
to compilation of the software program, encrypting only the second portion of source code. 

33. (Unamended) The method of claim 32 wherein the second processor is a smart card. 

34. (New) The method of claim 1 wherein the software program is an application program. 
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35. (New) The method of claim 9 wherein the software program is an application program. 



36. (New) The method of claim 15 wherein computer program is an application program. 



37. (New) The method of claim 17 wherein the computer program is an application program. 



38. (New) The apparatus of claim 22 wherein the computer program is an application program. 



39. (New) The method of claim 26 wherein the software code is part of an application program. 



40. (New) The method of claim 30 wherein the software program is an application program. 



41. (New) The method of claim 32 wherein the software program is an application program. 



